class Vue{
    //vue相当于是一个容器 把要的东西都集中在一起 然后在其中调用 Observer Compiler等对象 处理容器中的内容
    constructor(options){
        //1.通过属性保存选项数据
        this.$options = options || {}
        this.$data = options.data || {}
        this.$el = typeof options.el === 'string' ? document.querySelector(options.el) : options.el
        //2.把data中的成员转换成getter和setter 注入到vue 实例中
        this._proxyData(this.$data)
        //3.调用observer对象,监听数据的变化
        new Observer(this.$data)
        //4.调用compiler对象，解析指令和差值表达式
        new Compiler(this)
    }

    _proxyData (data){
        //遍历data中的所有属性
        Object.keys(data).forEach(key=>{
            //把data的属性注入到vue实例中
            Object.defineProperty(this,key,{
                enumerable:true,
                configurable: true,
                get(){
                    return data[key]
                },
                set (newValue) {
                    if(newValue === data[key]){
                        return
                    }
                    data[key] = newValue
                }
            })
        })
        
    }
}